# Timer / Counter

Second Release wide frequency range

## **General Description**

The SASO\_TIMER implements a down counter/timer with 8-bit length. On the rising edge of the *MCLK*, the *Counter Register* (*CR*) value is decremented. When *CR0..7* equals to zero *Terminal Count (TC)* is set active during the second half of MCLK and the flag *nTC\_FF* is activated. The *Counter Register* is then reloaded with the value that has been preloaded into the *Load Register* (*LR*) renewing consecutive operation cycles. Flag *nTC\_FF* is cleared when a reading of the timer occurs.

# ISEL INSTITUTO SUPERIOR DE ENGENHARIA DE LISBOA

SASO\_TIMER\_v2

### **Functional Block Diagram**



## **Pin Configuration**



SkinnyDIP

**Top View** 

```
CUPL Implementation
        TIMER_v2 ;
Name
PartNo 00;
        21/12/2015 ;
Date
Revision 2.0 ;
Designer PM/hm ;
Company CCISEL ;
Assembly None ;
Location ;
Device
       √750c ;
/* ********** INPUT PINS *************/
            = MCLK
PIN 1
PIN [2..9] = [Din0..7]
            = !RD
PIN 10
PIN 11
            = !WR
PIN 13
             = !CE
/* ********* OUTPUT PINS *************/
PIN 14
        = TC
           = !TC FF
PIN 15
PIN [16..23] = [CR7..0]
/* ********* PINNODES *****************/
PINNODE [27..34] = [LR0..7]
/* ******** BODY ****************/
/* Load Register definition */
[LR0..7].ar = 'b'0;
             = 'b'0;
[LR0..7].sp
[LR0..7].ck
             = !WR;
[LR0..7].d = CE & [Din0..7] # !CE & [LR0..7] ;
/* Counter Register definition */
[CR0..7].ar = 'b'0;
[CR0..7].sp
             = 'b'0;
[CR0..7].ckmux = MCLK;
/* CR0.t = (!TC & 'b'1) # (TC & (CR0 $ LR0)) */
CR0.t = !TC # (CR0 $ LR0) ;
REPEAT i = [1..7]
  CR\{i\}.t = (!TC \& ![CR0..\{i-1\}]:\&) # (TC \& (CR\{i\} $ LR\{i\})) ;
SREPEND
zero = ![CR0..7]:& ;
/* TC is a glitch free signal,
constrained to the second half of MCLK */
TC = zero & !MCLK ;
/* Terminal Count flip-flop definition */
TC FF.sp = 'b'0;
TC FF.d = 'b'1;
TC FF.ck = TC;
/* reading the Timer <=> nTC FF acknowledgement */
RD Timer = RD & CE ;
[CR0..7].oe = RD Timer ;
  TC_FF.ar = RD_Timer ;
```



SASO\_TIMER\_v2